<!DOCTYPE html>
<html lang="en" xmlns:th="http://www.thymeleaf.org">
<head>
    <meta charset="utf-8"/>
    <link rel="apple-touch-icon" sizes="76x76" href="/img/apple-icon.png">
    <link rel="icon" type="image/png" href="/img/favicon.png">
    <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1"/>
    <title>
        AntRpc Console
    </title>
    <meta content='width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=0, shrink-to-fit=no'
          name='viewport'/>
    <!--     Fonts and icons     -->
    <link href="/css/google-fonts.css" rel="stylesheet"/>
    <link rel="stylesheet" href="/css/fontawesome-v5.7.1-all.css">
    <!-- CSS Files -->
    <link href="/css/bootstrap.min.css" rel="stylesheet"/>
    <link href="/css/now-ui-dashboard.min.css" rel="stylesheet"/>
    <link href="/css/my.css" rel="stylesheet"/>
    <!-- CSS Just for demo purpose, don't include it in your project -->

</head>
<body>
<div class="wrapper ">
    <div th:replace="~{common :: #common-sidebar}"></div>
    <div class="main-panel" id="main-panel">
        <nav id="common-config-nav" class="navbar navbar-expand-lg navbar-transparent  bg-primary  navbar-absolute">
            <div class="container-fluid my-padding-left-top-0">
                <div th:replace="~{common :: #commons-nav-btns}"></div>
                <div class="collapse navbar-collapse justify-content-end w-100" id="config-navigation">
                    <form style="width: 100%;" action="/configs">
                        <div class="input-group no-border">
                            <input type="text" name="keyword" class="form-control" placeholder="Search...">
                            <div class="input-group-append">
                                <div class="input-group-text">
                                    <i class="now-ui-icons ui-1_zoom-bold"></i>
                                </div>
                            </div>
                        </div>
                    </form>
                </div>
            </div>
        </nav>
        <div class="panel-header panel-header-sm"></div>
        <div class="content">
            <div class="row">
                <div class="col-md-12">
                    <div class="card card-chart">
                        <div class="card-header">
                            <h5 class="card-title">配置环境列表</h5>
                            <div class="dropdown">
                                <button type="button"
                                        class="btn btn-round btn-icon dropdown-toggle btn-outline-default no-caret"
                                        data-toggle="dropdown">
                                    <i class="now-ui-icons loader_gear"></i>
                                </button>
                                <div class="dropdown-menu dropdown-menu-right">
                                    <a class="dropdown-item" href="#" data-toggle="modal"
                                       data-target="#create_env_modal">新建环境</a>
                                    <a class="dropdown-item" href="#" data-toggle="modal"
                                       data-target="#query_config_fuzzy_modal">模糊查询</a>
                                </div>
                            </div>
                        </div>
                        <div class="card-body">
                            <div class="table-responsive">
                                <table class="table">
                                    <thead class="text-primary">
                                    <tr>
                                        <th>#</th>
                                        <th>环境名称</th>
                                        <th></th>
                                    </tr>
                                    </thead>
                                    <tbody>
                                    <tr th:each="env, itStat : ${envs}">
                                        <td th:text="${itStat.index + 1}"></td>
                                        <td th:text="${env}"></td>
                                        <td>
                                            <button type="button" rel="tooltip" title="配置空间"
                                                    class="btn btn-info btn-icon btn-sm "
                                                    th:attr="data-env=${env}"
                                                    onclick="goto_config_spaces(this)">
                                                <i class="now-ui-icons design_bullet-list-67"></i>
                                            </button>
                                            <button type="button" rel="tooltip" title="删除"
                                                    class="btn btn-info btn-icon btn-sm "
                                                    th:attr="data-env=${env}"
                                                    onclick="delete_env(this)">
                                                <i class="now-ui-icons ui-1_simple-remove"></i>
                                            </button>
                                        </td>
                                    </tr>
                                    </tbody>
                                </table>
                            </div>
                        </div>
                    </div>
                </div>
            </div>
        </div>
    </div>
</div>

<div class="modal fade" id="create_env_modal" tabindex="-1" role="dialog" aria-labelledby="myModalLabel"
     aria-hidden="true">
    <div class="modal-dialog">
        <div class="modal-content">
            <div class="modal-header justify-content-center">
                <button type="button" class="close" data-dismiss="modal" aria-hidden="true">
                    <i class="now-ui-icons ui-1_simple-remove"></i>
                </button>
                <h4 class="title title-up">新建环境</h4>
            </div>
            <div class="modal-body">
                <div class="container-fluid">
                    <div class="row">
                        <div class="col-md-12">
                            <div class="form-group">
                                <label for="env_name_elem">名称:</label>
                                <input type="text" class="form-control" id="env_name_elem"/>
                            </div>
                        </div>
                    </div>
                </div>
            </div>
            <div class="modal-footer">
                <button type="button" class="btn btn-primary" onclick="save_env_name();">保存</button>
                <button type="button" class="btn btn-default" data-dismiss="modal">关闭</button>
            </div>
        </div>
    </div>
</div>

<div class="modal fade" id="query_config_fuzzy_modal" tabindex="-1" role="dialog" aria-labelledby="myModalLabel"
     aria-hidden="true">
    <div class="modal-dialog">
        <div class="modal-content">
            <div class="modal-header justify-content-center">
                <button type="button" class="close" data-dismiss="modal" aria-hidden="true">
                    <i class="now-ui-icons ui-1_simple-remove"></i>
                </button>
                <h4 class="title title-up">模糊查询条件</h4>
            </div>
            <div class="modal-body">
                <div class="container-fluid">
                    <div class="row">
                        <div class="col-md-12">
                            <div class="form-group">
                                <label for="config_pattern_elem">模式:</label>
                                <input type="text" class="form-control" id="config_pattern_elem"/>
                            </div>
                        </div>
                    </div>
                </div>
            </div>
            <div class="modal-footer">
                <button type="button" class="btn btn-primary" onclick="query_config_fuzzy();">查询</button>
                <button type="button" class="btn btn-default" data-dismiss="modal">关闭</button>
            </div>
        </div>
    </div>
</div>

<div th:insert="js"></div>
<script>

    function query_config_fuzzy() {
        window.location.href = "/configFuzzyQuery?pattern=" + $.trim($("#config_pattern_elem").val());
    }

    function goto_config_spaces(btn) {
        window.location.href = "/configSpaces?envName=" + $(btn).attr("data-env");
    }

    function delete_env(btn) {
        var envName = $(btn).attr("data-env");
        $.ajax({
            url: "/config/deleteEnv",
            type: "POST",
            data: {
                "envName": envName
            },
            dataType: "JSON",
            success: function (response) {
                if (response.code === 2000) {
                    antrpc_console.showNotification("删除成功!");
                } else {
                    antrpc_console.showNotification(response.message, {
                        "color": "danger"
                    });
                }
                window.setTimeout(function () {
                    window.location.reload();
                }, 1000);
            }
        });
    }

    function save_env_name() {
        var envName = $.trim($("#env_name_elem").val());
        if (!envName) {
            antrpc_console.showNotification("环境名称不能为空!");
            return;
        }
        $.ajax({
            url: "/config/saveEnv",
            type: "POST",
            data: {
                "envName": envName
            },
            dataType: "JSON",
            success: function (response) {
                if (response.code === 2000) {
                    antrpc_console.showNotification("保存成功");
                    $("#create_env_modal").modal("hide");
                    window.setTimeout(function () {
                        window.location.reload();
                    }, 1000);
                } else {
                    antrpc_console.showNotification(response.message, {
                        color: "danger"
                    });
                }
            }
        })
    }

    $(document).ready(function () {
        $("#config_list_li").addClass("active");
    });

</script>
</body>
</html>